<template>
  <div>
    <van-nav-bar
      left-arrow
      @click-left="onClickLeft"
      fixed
      :title="middle"
      :right-text="right"
      @click-right="emits('clickRight')"
    ></van-nav-bar>
  </div>
</template>

<script setup lang="ts">
// 一定有的功能：返回图标，返回效果，固定定位（组件内部实现）
// 使用组件时候才能确定的功能：标题，右侧文字，点击右侧文字行为（props传入）
import { useRouter } from 'vue-router'

// 接收数据 父传子
const props = defineProps<{
  middle?: string
  right?: string
  back?: () => void
}>()
// 点击左侧返回
const router = useRouter()
const onClickLeft = () => {
  console.log('点击返回')
  if (props.back) {
    return props.back()
  }
  if (history.state?.back) {
    router.back()
  } else {
    router.push('/home')
  }
}
// 点击右侧子传父
const emits = defineEmits<{
  (e: 'clickRight'): void
}>()
</script>

<style lang="scss" scoped>
::v-deep() {
  .van-nav-bar {
    &__arrow {
      font-size: 18px;
      color: var(--cp-text1);
    }
    &__text {
      font-size: 15px;
    }
  }
}
</style>
